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[57] ABSTRACT 

A distributed computer system, as for transmitting and 
receiving executable multimedia applications, includes a 
source of a continuous data stream repetitively transfering 
data representing a distributed computing application and a 
client computer, receiving the data stream, for extracting the 
distributed computing application representative data from 
the data stream, and executing the extracted distributed 
computing application. 
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APPARATUS FOR TRANSMUTING AND 
RECEIVING EXECUTABLE APPUCATIONS 
AS FOR A MULTIMEDIA SYSTEM 



The present invention relates to a cliem-server dislrib- 5 
utcd computer system. Such a compuicr system has appli- 
cation in broadcast multimedia applications. 

Early computer systems were standalone systems, con- 
sisting generally of mainframe computers. Later, several 
mainframe computer systems were closely connected, or lo 
clustered, to handle larger computing jobs, such as a large 
number of time sharing users. With the advent of peisoaal 
computers, large numbers of relatively low power standal- 
one computer systems were controlled directly by their 
users. Soon these large numbers of personal computers were is 
coupled together into networks of computers, providing 
shared resources and communications capabilities to the 
users of the individual personal computers and between 
those users and the preexisting mainframe computers. 

One form of sudi a network includes a central computer, 20 
called a server, which generally includes a large amount of 
mass storage. Programs used by the network users are 
centrally stored in the mass storage on the server. When a 
user desires to run a program, the user's computer requests 
that a copy of that program be sent to it from the server. In 2S 
response to that request, the server transfers a copy of the 
program from its mass storage to the main memory of the 
personal computer of that user, and the program executes on 
that personal computer. Data also may be centrally stored in 
the server and shared by all the users on the network. The 30 
data is stored on the mass storage of the server, and is 
accessible by all the network users in response to a request. 
The server also serves as a bub for communications of 
messages (electronic mail) between network users The 
server in such a system handles the storage and distribution 35 
of the programs, data and messages, but does not contribute 
any processing power to the acmal computing tasks of any 
of the users. I.e. a user cannot expect the server computer to 
perform any of the processing tasks of the program execut- 
ing on the personal computer. While such networks perform 40 
a valuable function, they arc not distributed computing 
systems, in which interconnected computers cooperate to 
perform a single computing task. 

In an improvement to such networks, the network may be 
configured in such a manner that a user on the network may 45 
request that the server, or other personal computer connected 
to the network, execute a program. This is termed remote 
execution because a computer (server or other personal 
computer) remote from the requester is executing a program 
in response to a request from the requester. In such a system, so 
the program of which remote execution is requested is either 
sent from the requester to the remote computer, or retrieved 
from the server in response to a request by the remote 
computer. When the program is received, it is executed. In 
this manner several computers may be enlisted to cooperate ss 
in performing a computing function. 

Recently, there have been programs which distribute the 
actual computing tasks necessary for performing a single 
computing function. For example, in such a data base 
program, where the data base is stored in the mass storage 60 
of the server, if a user desires to make a query of the data 
base, the portion of the data base management program on 
that user's personal computer will generate a query request, 
which is forwarded to the server. The portion of the data base 
management program on the server performs the query 65 
processing, e.g. parsing the query request, locating where 
the data speci&ed in the query request resides on its mass 
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APPARATUS FOR TRANSMITTING AND 
RECEIVING EXECUTABLE APPUCATIONS 
AS FOR A MULTIMEDIA SYSTEM 

The present invention relates to a client-server distrib- 5 
uted computer system. Such a computer system has appli- 
cation in broadcast multimedia applications. 

Early computer systenas were standalone systems, con- 
sisting generally of main&ame computers. Later, several 
mainframe computer systems were closely connected, or lo 
clustered, to handle larger computing jobs> such as a large 
number of time sharing useis. With the advent of personal 
computers, large nimibcrs of relatively low power standal- 
one computer systems were controlled directly by their 
users. Soon these large numbers of personal computers were is 
coupled together into nctwote of computers^ providing 
shared resources and commtinications capabQities to the 
users of the individual personal computers and between 
those users and the preexisting mainframe computers. 

One form of sucdi a network includes a central computer, ZQ 
called a server, which generally includes a large amount of 
mass storage. Programs used by the network tiseis are 
centrally stored in the mass storage on the server. When a 
user desires to run a program, the user's computer requests 
that a copy of that program be sent to it horn the server. In 25 
response to that request, the server transfers a copy of the 
program &om its mass storage to the main memory of the 
personal computer of that user, and the program executes on 
diat personal computer. Data also may be centrally stored in 
the server and shared by ail the users on the networic. The 30 
data is stored on the mass storage of the server, and is 
accessible by all the network users in response to a request. 
The server also serves as a hub for communications of 
messages (electronic mail) between network users The 
server in such a system handles the storage and distribution 35 
of the programs, data and messages, but does not contribute 
any processing power to the acmal computing tasks of any 
of the users. I.e. a user cannot expect the server computer to 
perform any of the processing tasks of the program execut- 
ing on the personal computer. While sudi networks perform 40 
a valuable function, they are not distributed computing 
systems, in which interconnected computers cooperate to 
perform a single computing task. 

In an improvement to such networks, the necwodc may be 
configured in such a manner that a user on the network may 45 
request that the server, or other personal computer connected 
to the network, execute a program. This is termed remote 
execution because a computer (server or other personal 
computer) remote &om the xequester is executii^ a program 
in response to a request from the requester. In such a system, so 
the program of which remote execution is requested is either 
sent from the requester to the remote computer, or retrieved 
from the server in response to a request by the remote 
computer When the program is received, it is executed. In 
this manner several computers may be enlisted to cooperate 55 
in performing a computing function. 

Recently, there have been programs which distribute the 
actual computing tasks necessary for performing a single 
computing function. For example, in such a data base 
program, where the data base is stored in the mass storage 60 
of the server, if a user desires to make a query of the data 
base, the portion of the data base management program on 
that user's personal computer will generate a query request, 
which is forwarded to the server. The portion of the data base 
management program on the server performs the query 65 
processing, e.g. parsing the query request, locating where 
the data specified in the query request resides on its mass 
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Storage device, accessing that data, and sending the results 
back to the requesting personal computer over the network. 
The portion of the data base management program on the 
personal computer then processes the data received from the 
5 server, e.g. formatting it, and displaying it on the screen or 
printing it on a printer. While the server is processing the 
query request, the personal computer is free to perform other 
processing, and while the personal computer is generating 
the query request, and processing the resulting data received 
from the server, the server is free to process query requests 
from other personal computers. 

Other types of programs arc also amenable to this type of 
distributed computing, termed client-server computing. The 
sharing of the processing tasks between the personal com- 
puter and the server improves the overall efficiency of 
^5 computing across the network. Such client-server computer 
systems, and remote execution networks, may be termed 
distributed computing systems because several computers 
(the server and/or the respective peripheral computers) 
cooperate to perform the computing function, e.g. data base 
20 management. 

Recently, broadcast multimedia programs, more 
specifically, interactive television (TV) programs, have been 
proposed. Interactive TV programs will allow a viewer of a 
television program to interact with that program. In an 
25 interactive TV system, the central broadcast location (TV 
network, local TV studio, cable system, etc.) will have a 
central computer, corresponding to the server computer, 
which will produce signals related to the interactive TV 
program to be broadcast simultaneously with the TV (video 
30 and audio) signals. These signals carry data representing the 
interactive TV program and may include comminds, execut- 
able program code and/or data for controlling the viewer 
interaction. Each viewer location will have a computer, 
corresponding to the client computer, which will receive the 
)5 commands, executable code and/or data from the central 
computer, execute the executable code, process the received 
data, accept input from the user and provide data to the user 
by means of the TV screen. The input from the user may be 
sent back to the computer at the broadcast location, allowing 
40 the user to interact with the interactive TV program. 

U,S. Pat. No, 4,965,825, SIGNAL PROCESSING 
APPARATUS AND METHODS, issued Oct. 23, 1990 to 
Harvey et al., describes an interactive TV system in which 
a central broadcast location includes signals carrying 
45 commands, executable code and data in, for example, the 
vertical blanking interval of the television signal for receipt 
by the computer systems at the viewer locations. Acomputcr 
at the viewer location extracts the commands, executable 
code and data and executes the code to process the data and 
so interact with the user. Such a system is comparable to the 
remote execution function of distributed computer systems, 
described above, in that the viewer computer is enlisted into 
the interactive TV program, and is controlled by the central 
location. 

55 In all of die above systems, a central computer controls 
or responds to requests from peripheral computers attached 
to it through a network. I.e. the peripheral computer 
(personal computer) requests remote execution of a 
program, requests a file or message from, or sends a query 

60 request to, another computer. Only in response to a request 
does the other computer provide a response, e.g. remote 
execution, the requested file, message or retrieved data. In 
addition, in general, the peripheral computer is required to 
have all the resources necessary to completely, or ahnost 

65 completely, execute the desired program, with the server 
acting only as another storage mechanism or at most sharing 
a portion of the computing tasks. 



The inventors propose a distributed computing system in 
which a server computer continuously produces a data 
stream. This data stream acts a mass storage device for the 
client computers receiving it. This data stream repetitively 
includes data representing a distributed computing applica- 5 
tion in which the client computer may participate, including 
executable code and data. A transport mechanism, including 
a high speed, one-way, communication path, carries the data 
stream from the server to the client The client receives the 
data stream, extracts the distributed computing reprcsenta- lo 
tive data and executes the distributed computing application. 

In accordance with princ^les of the present invention, a 
distributed computer system comprises a source of a con- 
tinuous data stream repetitively including data representing 
a distributed computing application and a client computer, 15 
receiving the data stream, for extracting the distributed 
computing application representative data from the data 
stream, and executing the extracted distributed computing 
application. 

In a distributed computing system according to the 20 
invention, the client computer system need not include all 
the resources, in particular, main memory and mass storage, 
necessary to perform the entire program. Instead, no mass 
storage is required because the data stream provides the 
function of the mass storage device, and the main memory 25 
requirement is modest because only the currently executing 
portion of the program need be stored in memory. When the 
currently executing portion has completed, its memory 
space is freed up, and the next executing portion is extracted 
from the data stream, stored in the freed memory space, and 30 
that portion begins execution. 

In addition, a distributed computing system according to 
the present invention allows the user of the client computer 
to have the option participating in the distributed computing 
task. If it is desired to participate, the client computer 35 
extracts *the data representing the distributed computing 
application and executes the distributed computing 
application, as described above. If it is desired not to 
participate, the data stream is merely ignored, and the 
processing desired by the user, or none at all, is performed. 40 
Such a distributed computing system also allows each 
participating client computer lo join the distributed comput- 
ing function at any time and to proceed at its own pace in 
performing its own computing function. 

A distributed computing system according to the present 45 
invention is particularly amenable to interactive TV appli- 
cations because it allows a viewer to tune into an interactive 
TV channel at any time, join in the interactivity whenever 
desired (or not at all), and allows all the viewers lo proceed 
at their different paces. This is especially advantageous in an 50 
environment when an interactive commercial, with its own 
executable code and data, may be presented within an 
interactive program, or when the viewer wishes to change 
channels. 

In the drawing: 55 

FIG. 1 is a block diagram of a distributed computing 
system according to the present invention; 

FIG. 2 is a block diagram of a server computer as 
illustrated in FIG. 1; 

FIG, 3 is a timing diagram illustrating the data streams 60 
produced by a server computer in a distributed computing 
system as iUustrated in FIG. 1; 

FIG. 4 is a block diagram of a client computer as 
illustrated in FIG. 1. 

FIG. 1 is a block diagram of a distributed computing 65 
system according to the present invention. In FIG. 1, a server 
computer 10, which may include a large computer system. 
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is coupled lo a plurality of client computers 20 through a 
transport mechanism 30. The server computer 10 may be 
coupled to more than the three client computers 20 illus- 
trated in FIG. 1, and the client computers 20 may be 
5 geographically widely dispersed. Client: computer 22 is 
bidirectionally coupled to a local computer 40, to an auxil- 
iary data processing system 50 and to a central processing 
fadlity 60. The central processing facility 60 is bidirection- 
ally coupled to the server computer 10. TTie central proccss- 
10 ing facility 60 may also be connected to facilities other than 
the server computer 10 illustrated in FIG. 1. The local 
computer 40 is further bidirectionally coupled to a mass 
storage device 70. The client computer 22 interacts with a 
user 80 by providing information to the user via a display 
IS screen or other output device (not shown) and by accepting 
information from the user via a keyboard or other input 
device (also not shown). 

Ciient computers 24 and 26 also interact with their users, 
(not shown in order to simplify the drawing). In addition, 
20 client computers 24 and 26 are bidirectionally coupled to the 
central processing facility 60. Suc± links are optional, how- 
ever. The only requirements for any client computer 20 is a 
way to interact with a user, and a collection to the transport 
mechanism 30. Lixiks to local computers, auxiliary data 
25 processing systems, and the central processing faciUty 60 
arc all optional, ai]d need not be present in every one of the 
client computers 20. 

The transport mechanism 30 includes a unidirectional 
high speed digital data link, such as a direct fiber optic or 
30 digital satellite link from the server 10 to the client com* 
puiers 20. The data may be transported over the transport 
system 30 by a packet data system. In such a system, a 
stream of data packets, each includir^ identification infor* 
mation indicating, among other things, the type of data 
35 contained Id that packet and the actual data, is transmitted 
through the data link. Such a packet data system allows 
several independent streams of data, each identified by 
identification information in their packets, to be time mul- 
tiplexed within a single stream of packets. 
40 In addition, it is possible to multiplex a plurality of such 
packet data streams over respective channels on the same 
physical medium (fiber optic or satellite radio link) making 
up the transport mechanism 30. For example, different data 
streams may be modulated on carrier signals having differ- 
45 cnt frequencies. These modulated carriers may be transmit- 
ted via respective transponders on a satellite link, for 
example. Further, if a particular transponder has sufQcient 
capacity, it is possible to time mdtiplex several data streanas 
on a single modulated carrier. 
50 The client computers 20 each contain a data receiver for 
selectii^ one of the streams of packets being transported 
over the transport mechanism 30, receiving the selected 
stream of packets and extracting the data contained in them. 
Continuing the above example, the data receiver may 
55 include a tunable demodulator for receiving one of the 
respective modulated carriers from the satellite link. In 
addition, the data receiver may include circuitry for time 
demultiplexing the respective data streams being carried by 
that modulated carrier. 
60 In operation, the server 10 produces a continuous data 
stream in the form of a stream of packets for the client 
computers 20, The server 10 repetitively inserts a packet, or 
successive packets, containing data representing the distrib- 
uted computing application, including at least one execut- 
es able code module, into the data stream. This code module 
contains executable code for the client computers 20. The 
data receiver in, for example, chent computer 22, continu- 
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ously monilors the packets in the data stream on transport 
mechanism 30. When a packet including identification infor- 
mation indicating that it contains the code module (or a 
portion of the code module) required by the client computer 
22 is present in the data stream, the client computer 22 5 
delects its presence, extracts the code module (or the portion 
of the code module) from that packet and stores it in the 
main memory. When the code module is completely 
received, the client computer 22 begins to execute it 

There may be more than one code module placed in the lo 
continuous data stream, each containing a difi^rent portion 
of the distributed computing application. For example, it is 
possible to divide the distributed computing application into 
small portions in such a manner that only one portion at a 
lime need be executed at a time. The portion of the distrib- 15 
uted computing application currently needed to execute is 
loaded into the memory of the client computer 22. When that 
portion has completed its execution, then a code module 
containing the executable code for the next portion of the 
distributed computing application is extracted &om the data 20 
stream, stored in memory and executed. Each portion is 
extracted firom the data stream as needed. If there is suffi- 
cient memory in the client computer 22, it is possible to load 
several code modules into the memory and switch between 
them, without extracting them from the data flow, but this is 25 
not necessary. By structuring a distributed computing appli- 
cation in this manner, the required memory size of the client 
computer 22 may be minimized. 

The server 10 may also repetitively include a packet or 
packets containing one or more data modules in the data 30 
stream. The data modules contain data to be processed by the 
executable code in the code module. Prior to, or during the 
execution of the code from a previously extracted code 
module, the client computer 22 may require access to the 
data in the data module or modules. If so, the client 35 
computer 22 monitors the data stream for the required data 
module or modules. When packets containing the data 
module or modules (or portions of the data module or 
modules) are present in the data stream, they are extracted, 
and the contents stored in the main memory of the client 40 
computer 22. When all the required data modules have been 
completely received, the client computer 22 begins or con- 
tinues execution of the code from the code module to 
process the data &om the received data module or modules. 
As is the case for code modules, it is possible for more than 4S 
one data module to be stored in memory, if there is sufficient 
memory in client computer 22. 

The server 10 may further repetitively include in the data 
stream a packet or packets containing a directory of the code 
and data modules currently being included in the data 50 
stream. The directory includes a list of all the code and data 
modules which are present in the data stream, along with 
information about those modules. If a directory is present in 
the data stream, then, prior to extraction of any code or data 
modules from the data stream, the client computer 22 ss 
monitors the data stream for the directory. When packets 
containing the directory (or portions of the directory) are 
present in the data stream, they are extracted, and their data 
Stored in the main memory of the client computer 22. When 
the directory has been completely received, the client com- 60 
puter 22 evaluates the entries in the directory, then requests 
the first code and/or data module from the data stream and 
execution proceeds as described above. 

Any of the client computers 20 may join the distributed 
computing function represented by the packet stream at any 65 
time, and each of the client computers 20 may operate at its 
own speed, generally in response to the user 80. In order to 
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allow for ihis, the server 10 repetitively places the directory 
and all the code and data modules which the client comput- 
ers 20 may require to perform their portion of the distributed 
computing function into the data stream on the transport 

5 mechanism 30. Whenever one of the client computers 20 
joins the distributed computing function, it monitors the 
newly selected packet stream on the transport mechanism 30 
for the directory module, extracts it, and processes it as 
described above. During execution, whenever one of the 

10 client computers 20 requires the a new code and/or data 
module, it monitors the data stream on the transport mecha- 
nism 30 for the newly required code and/or data module, 
extracts it and either executes it, if it is a code module, or 
processes it if it is a data module, as described above. 

15 The packet data sucam may also include packets of 
auxiliary data. This data is not required by the client 
computer 22 for execution of the code, although it may be 
related to the execution because the user 80 may interact 
with the executing program on the client computer 22 based 

20 on received auxiliary dau. The data stream receiver in the 
client computer 22 recognizes the auxiliary data packets in 
the data stream on the transport mechanism 30 and passes 
them directly to the auxiliary data processor 50. The auxil- 
iary data processor 50 processes its packets independently of 

25 the client computer 22. If the auxiliary data must be pre- 
sented to the user 80, the auxiliary data processor 50 may 
provide its own display device (not shown) which may be 
shared with the client computer 22, or the display device 
(not shown) associated with the client computer 22 may be 

30 shared with the auxiliary data processor 50, to provide a 
single information display to the user 80. The auxiliary data 
processor 50 may have links to other illustrated elements in 
(not shown), but that is dependent upon the type of data. 
In an interactive TV system, for example, the auxiliary 

35 data includes the video and audio portions of die underlying 
television signal. For example, the auxiliary data would 
include video packets containing MPEG, or MPEG-like, 
encoded data representing the television image and audio 
packets containing digitally encoded audio. Further, there 

40 may possi*bly be several different audio packet streams 
carrying respective audio channels for stereo, second audio 
program (SAP) or multilanguage capability. In an auxiliary 
data processor 50 in such a system, the video packets would 
be supplied to a known MPEG (or similar) decoder (not 

45 shown) which would generate standard video signals, which 
would be supplied to a television receiver or video monitor 
(not shown). The audio packets would be supplied to a 
known audio decoder (not shown) which would generate 
standard audio signals for the television receiver or speakers 

50 (not shown). 

In such an interactive TV system, the client computer 22 
may, in response to execution of the executable code 
module, generate graphic displays to supply information to 
the user 80. These graphic displays may be combined with 

55 the standard video signal from the MPEG decoder in a 
known manner, and the combined image displayed on the 
television receiver or video monitor. The client computer 22 
may also generate sounds to provide other information to the 
viewer. The generated sounds may be combined, in known 

60 manner, with the standard audio signals from the audio 
decoder, and the combined sound played through the tele- 
vision receiver or speakers. 

Furthermore, lime code data may be included in either or 
both of the television auxiliary packet data stream and the 

65 packet data stream representing the interactive TV applica- 
tion. This permits synchronization of any graphic images or 
sounds generated by the client computer 22 with the tele- 
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vision signal from Ihe auxiliary data. In this case, the client 
computer 22 would have access to the time code data, and 
would control the generation of the graphic image and/or 
sound to occur at the desired time, as supplied by the time 
code data. 5 

In such an interactive TV system, both the client com- 
puter 22 and the auxiliary data processor 50 may be con- 
tained in a single enclosure, such as a television receiver, or 
television set-top decoder box, A television receiver, or 
decoder box would include connectors for attaching lo a 
local computer or other equipment. 

The user 80 provides input to the program running on the 
client computer 22 during its execution. This data may be 
required by the server 10 in order to effect the distributed 
computing function. In an interactive TV system, for 
example, user 80 may provide input to the client computer 
through a handheld remote control unit. 

The user data is transferred lo the server computer 10 via 
the central processing facility 60. In one embodiment, data 
is sent from the client computers 20 to the server computer 
10 via modems through the telephone system acting as the 20 
central processing facility 60. The server computer 10 
receives and processes the data received from the client 
computers 20 during execution of its portion of the distrib- 
uted computing function. 

Server computer 10 may generate new, or modify 25 
existing, code and/or data modules in the data stream on the 
transport mechanism 30, in a manner described below, based 
on that received data. Alternatively, the server computer 10 
may immediately return ioformation to the client computers 
20 in the other direction through the central processing 30 
facility 60. The information in newly generated code and/or 
data modules is processed by all client computers 20 par- 
ticipating in the distributed computing fuiKtion, while infor- 
matioQ passed &om the server computer 10 to the client 
computers 20 throu^ the central processing facility 60 is 3S 
specifically related to the client computer (22, 24, 26) to 
which that information was sent. 

In another embodiment, the central processing facility 60 
may include its own computer system, separately connected 
by modem to both the client computers 20 and the server 40 
computer 10 through the telephone system. In either of the 
above embodiments, the central computing facility 60 pro* 
vides access to other computers or processing facilities (not 
shown) via the telephone system. Thus, if information from 
other computer systems is needed to perform the distributed 4S 
computing function, those computer systems may be 
accessed via modem through the telephone system by either 
the client computers 20 or the server computer 10. 

An input/output (I/O) port on the client computer 22 is 
coupled to a oonesponding port on the local computer 40. so 
Local computer 40 is collocated with the client computer 22. 
Local computer 40 may be a personal computer used by the 
user 80 of the client computer 22, or may be a larger 
computer, or computer network located at the same site as 
the client computer 22. This allows the client computer 22 55 
to access data on the attached mass storage 70 of the 
personal computer or a computer on the network located at 
the client computer 22 site. In addition, the client computer 
22 may use the mass storage 70 of the local computer 40 for 
storage of data to be retrieved later. It is likely that the local 60 
computer 40 will include both an output device (not shown) 
such as a computer monitor and an input device (also not 
shown) such as a computer keyboard. Both of these may be 
shared with the client computer 22 and/or the auxiliary data 
processor 50, as described above. 65 

For example, the distributed computing system illus- 
trated in may be pan of a widespread corporate computing 
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system, and the server 10 may be located at a central location 
of thai corporation- The client computer 22 may be located 
a remote location, and the local computer 40 may be coupled 
to the personal computer network at that location. Workers 
5 at that location may store shared data (e.g. fLnancial 
information) on the server connected to thai network. The 
distributed computing function may include gathering local 
financial data from the client computers at Uie remote 
locations, processing that financial data and returning over- 
10 all financial results to the client computers, in such an 
application, the executable code executing on the client 
computer 22 accesses the data from the local computer 40 
(either from its atuched mass storage 70 or through the 
network) through the I/O port, and sends it to the server 
15 computer 10 through the central pro<xssing fedlity 60. The 
server computer 10 continues its processing based on the 
information received from client computer 22 (and other 
client computers 20), and returns the results of that process- 
ing to the client computers 20 either through the central 
20 processing facility 60 or via the data stream on the transport 
mechanism 30. 

In another example, the distributed computing system 
may be an interactive television system, broadcasting a 
home shopping show as the distributed computing applica- 
25 tion. In such a case, the auxiliary data carries the video and 
audio portion of the television signal, which may show and 
describe the items being offered for sale, and may include 
both live actors and overlaid graphics generated at the 
central studio. Code and data modules making up the 
30 interactive television application may include data about the 
products which will be offered for sale during this show, or 
portion of the show, and executable code to interact with the 
user in the manner described below. 

When a viewer wishes to order an item, a button is 
35 pressed on the TV remote control. This button signals the 
client computer 22 to display a series of instructions and 
menus necessary to solicit the information necessary to 
place the order, e.g. the item number, name and address of 
the viewer, the method of payment, the credit card number 
40 (if needed), etc. These instructions are generated in the client 
computer as graphics which are overlaid on the television 
video image. It is also possible for a computer generated 
voice to be generated and combined with the television 
audio either by voice-over, or by replacing the television 
45 audio. The viewer responds to the instruction by providing 
the requested information via the TV remote control. When 
the information requested by the on-screen display and/or 
voice instructions has been entered by the viewer, it is sent 
to a central computer via the modem in the client computer. 
50 An order confiiination may be sent in the other direction 
from the central computer. 

It is also possible that permanent information about the 
viewer (i.e. the name, address, method of payment and credit 
card number) may be preentered once by the viewer, so it is 
55 not necessary to solicit that information each time an order 
is placed. The information is stored in permanent memory in 
the client computer. In such a case, when an order is placed, 
that information is retrieved from the permanent memory, 
appended to the item number and transmitted to the central 
60 computer. It is further possible that, by means of time codes, 
or other commands, inserted into the data stream, the client 
computer will know which item is currently being offered 
for sale. In such a case, the viewer will be able to order it by 
simply pressing one button on the TV remote control. In 
65 response, the cUent computer can combine the previously 
received information related to the item currently being 
offered for sale with the previously stored peisonal infor- 



malion related lo ibe viewer, and transmit the order to the 
central computer and receive the confirmation in return. 

Because the code and data modules related to the home 
shopping program are repetitively inserted into the data 
stream, a viewer may tune into the program at any time and 5 
be able to participate interactively. Similarly, it is not nec- 
essary for the viewer to participate interactively, but may 
simply ignore the interaaive portion of the show. 

It is also possible for the client computer 22 to receive 
control information from the local computer 40. For lo 
example, the user 80, using the local computer 40, could 
control the client computer 22 via the I/O port lo select a 
desired one of the data streams on transport mechanism 30, 
and process the program currently being broadcast on that 
data stream, with interaction with the user 80 through the is 
input and output devices (not shown) connected to the local 
computer 40. 

It is further possible for the user 80 to cause the client 
computer 22 to access the server computer 10 through the 
central processing facility 60, instead of via the data stream 20 
on transport mechanism 30, and receive code and data 
modules via this bidirectional lixik. 

FIG. 2 is a block diagram illustrating a server computer 
10 as illustrated in FIG. 1. In FIG. 2, a source of distributed 
computing application code and data 101 includes an appli- 25 
cation compiler, and software management moditle (not 
shown) and has an output terminal coupled to an input 
terminal of a flow builder 102. An output terminal of flow 
builder 102 is coupled to an input terminal of a transport 
packetizer 104. An output terminal of transport packetizer 30 
104 is coupled to a flrst input terminal of a packet multi- 
plexer 106. An output terminal of packet mtiltiplexer 106 is 
coupled to an input terminal of a transport multiplexer 110. 
An output terminal of transport mtiltiplexer HO is coupled 
to the physical medium maldng up the transport mechanism 35 
30 (of FIG. 1), Asecond input tcnninal of packet multiplexer 
106 is coupled to a source of auxiliary data packets 107. A 
clock 109 has respective output terminals coupled to corre- 
sponding input terminals of the transport packetiTer 104 and 
auxiliary data source 107. A data transceiver 103 has an first 40 
bidirectional terminal coupled to the central processing 
facility 60 (of FIG. 1) and a second bidirectional data 
coupled to the application code and data source 101. Appli- 
cation code and data source 101, flow builder 102, transport 
packetizer 104, auxiliary data source 107, clock 109 and 45 
packet multiplexer 106, in combination, form a channel 
source 108 for the transport mechanism, illustrated by a 
dashed box in. Other channel sources, including similar 
components as those illustrated in channel source 108 but 
not ^own in FIG. 1, are represented by another dashed box so 
lO&z. The other channel sources (108a) have output termi- 
nals coupled to other input terminals of the transport mul- 
tiplexer no, and may have input terminals coupled to 
central processing facilities through data transceivers. 

In operation, data representing the distributed computing 55 
application program, and data related to the transmission of 
the program over the transport mechanism 30 are supplied to 
the flow builder 102 from the application source 101. This 
data may be supplied either in the form of files containing 
data representing the code and data modules, or by scripts 60 
providing information on how to construct the code and data 
modules, or other such information. The code and data 
modules may be constant or may change dynamically, based 
on inputs received firom the client computers 20 via the 
cenu-al computing facility 60 and/or other sources. The 65 
executable code and data module flies may be generated by 
a compiler, interpreter or assembler in a known manner in 
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response to source language programming by an appiicalion 
programmer. The data file related to the transmissioQ of the 
modules includes such information as: the desired repeiiiion 
rates for the directory and the code and data modules to be 
5 included in the data stream; the size of main memory in the 
client computers 20 required to store each module, and to 
completely execute the application program; a priority level 
for the module, if it is a code module, etc. 

Flow builder 102 processes the data from the application 
10 source 101. In response, flow builder 102 constructs a 
directory module, giving an overall picture of the applica- 
tion program. The information in the directory module 
includes e.g. the identification of all the code and data 
modules being repetitively transmitted in the data stream, 
IS their size and possibly other information related to those 
modules. Then the application program representative data 
is processed to generate the code and data modules. The 
directory, code and data modules thus constructed are for- 
matted by adding module headers and error detection and/or 
20 correction codes to each module. A transmission schedule is 
also generated. After this processing is complete, the data 
representing the directory module and the code and data 
modules are repetitively presented to the transport pack- 
ctizer 104 according to the schedule previously generated. 
25 The transport packctizer 104 generates a stream of pack- 
ets representing the directory module and the code and data 
modules as they arc emitted firom the flow builder 102. Each 
packet has a constant predetermined length, and is generated 
by dividing the data stream &om the flow builder into groups 
30 of bits, and adding a packet header with information iden- 
tifying the information contained in the packet,'and an error 
detection and/or correction code, etc., to each group, such 
that each packet is the same predetermined length. (If there 
is insuf&cient data from the flow builder 102 to completely 
35 fill a packet, the packet is padded with null data.) These 
packets are time multiplexed with the auxiliary data packets, 
in a known manner, to form a single packet stream in the 
packet multiplexer 106. It is also possible for the generated 
packets to have varying lengths, in this case, the packet 
40 header for each packet will contain the length of that packet. 
In addition^ time code data packets are placed in the data 
stream packets and/or the auxiliary data packets based on 
data received from the clock 109. 

Packet streams from all of the channel sources (lOS, 
45 108a) are mtdtiplexed into a single transport channel, which 
is U-ansmitted through transport mechanism 30. As described 
above, the packet streams may be frequency multiplexed by 
having each packet stream modulate a carrier signal at a 
different frequency, with all of the carriers being carried by 
50 a satellite link to the client computers 20, in a known 
manner. In addition, if there is suf&cient capacity within one 
carrier channel, several packet streams may be statistically 
time multiplexed, and used to modulate a single carrier, also 
in a known manner. For example, it has been proposed to 
55 time multiples up to eight interactive television data streams 
through a single satellite link. 

Data from the chent computers 20 via the central pro- 
cessing facility 60 (of FIG* 1) is received at the server 
computer 10 by the data transceiver 103, which may include 
60 its own processor (not shown). If an immediate response is 
generated, the transceiver 103 processor returns that 
response via the central processing facility 60 to a specific 
client computer (22-26), a specific set of the client comput- 
ers 20 or to all client computers 20 in their turn. If, however, 
65 a common response to all client computers 20 is desired, the 
application programmer may amend the code and data files 
in the application code and data source 101 using the 
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application compiler. These amended files are then pro- 
cessed by the flow builder again to generate another flow. It 
is further possible that the code and data flies in the 
application source 101 may be amended automatically and 
dynamically (i.e. in real time) in response to data received 5 
from the transceiver 103, and the flow updated as the data is 
being received from the client computers 20. 

FIG. 3 is a timing diagram illustrating the data streams 
produced by the server computer 10 in a distributed com- 
puting system as illustrated in FIG. 1. In FIG. 3 server lo 
computer 10 is shown as simultaneously producing a plu- 
rality of packet streams 32-38. Each packet stream (32-38) 
is shown as a horizontal band divided into packets having 
the same duration and number of bits. As described above, 
it is possible that the size of the packets within any packet 15 
stteam vary with the amount of data to be carried. In FIG. 
3 it can be seen that the starting times of the packets are not 
synchronized. It is possible to synchronize the packets, but 
it in not necessary. In FIG. 3, packets carrying data repre- 
senting directories are designated DIR, packets carrying data 20 
representing code modules are designated CM, packets 
carrying data representing data modules arc designated DM, 
and packets carrying auxiliary data are designated AUX. 

In the top series of packets 32, the leftmost packet 
contains data representing a code module, CM. This is 25 
followed by three packets containing auxiliary data, AUX, 
foUowed by another packet containing data representing the 
code module, CM. From the series of packets 32 it can be 
seen that the code module is repetitively produced. There 
may be more or fewer packets in between successive rep- ao 
etitions of the code module packets CM. The rate of rep- 
etition may be specified by the programmer when the 
application is programmed, and may be varied during the 
execution of the application. 

In the next series of packets 34, the leftmost packet 35 
contains auxiliary data, AUX. The next two packets contain 
respective portions of a code module (CM1,CM2). The last 
packet contains auxiliary data, AUX. From the series of 
packets 34 it can be seen that if a code module is too large 
to be contained in a single packet, it may be carried by more 40 
than one, with each packet containing a portion of the code 
module. Although two packets are illustrated in the series of 
packets 34 as containing the code module (CM1,CM2), any 
number of packets may be used to carry the code module, 
depending upon its size. The two packets carrying the code 45 
module, (CM1,CM2) are repetitively transmitted (not 
shown) in the series of packets 34, as described above. 

In the series of packets 36, the leftmost packet contains 
data representing a code module (CM), llie next packet 
(DM1) is a first packet containing data representing a data so 
module. The next packet contains auxiliary data, AUX. The 
next packet (DM2) is a second packet containing the remain- 
ing data representing the data module. From the series of 
packets 36 it may be seen that a data module (DM1 J}M2), 
associated with the code module (CM), may also be included 55 
in the packet stream. Both the code module (CM) and the 
data module (DM1 J)M2) are repetitively transmitted (not 
shown) in the series of packets 36. The rate of repetition of 
the code module (CM) may be different from that of the data 
module (DM1,DM2), and both rates may be specified by the 60 
application programmer and varied during the execution of 
the application. 

It may further be seen that if the data module is too large 
to be contained in a single packet, it may be carried by more 
than one packet, with each packet containing a portion of the 65 
data module. Although two packets are illustrated in the 
series of packets 36 as containing the data module (DM1, 
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DM2), any number of packets may be used to carry the data 
module, depending upon its size. It may be further seen that 
the packets carrying the data module need not be transmitted 
sequentially, but may have intervening packets in the packet 
5 stream. The same is true for multiple packets carrying a code 
module or directory module (not shown). 

In the bottommost series of packets 38, the leftmost 
packet contains data representing the directory (DIR). The 
next packet contains data representing a code module (CM), 
followed by a packet containing auxiliary data (AUX) and a 
packet containing data representing a data module (DM). In 
the series of packet 38 all of a directory module (DIR), a 
code module (CM) and a data module (DM) in a single 
packet stream may be seen. The respective repetition rates of 
these three modules may be different, as specified by the 
^5 programmer of the application, and may be varied during the 
execution of the application. 

FIG. 4 is a block diagram of a client computer 22 as 
illustrated in FIG. 1. In FIG, 4, transport mechanism 30 (of 
FIG. 1) is coupled to an input terminal of a stream selector 
20 202. An output terminal of stream selector is coupled to 
respective input terminals of an auxiliary data extractor 204 
and a packet data extractor 206. An output terminal of 
auxiliary data extractor 204 is coupled to the auxiliary data 
processor 50 (of FIG. 1). A bidirectional terminal of packet 
25 data extractor 206 is coupled to a corresponding terminal of 
a stream I/O adapter 208. Acontrol output terminal of stream 
I/O adapter 208 is coupled to a corre^onding control input 
terminal of stream selector 202. The combination of stream 
selector 202, auxiliary data extractor 204 and packet data 
30 extractor 206 form a data stream receiver 207 for client 
computer 22, illustrated by a dashed line in FKj. 4. 

Stream I/O adapter 208 forms a part of a processing unit 
224 in client computer 22, illustrated by a dashed line in 
FIG. 4. In addition to the stream I/O adapter 208, processing 
35 unit 224 includes a processor 210, read/write memory 
(RAM) 212 and read-only memory (ROM) 214 coupled 
together in a known manner via a system bus 216, Further 
input and output facilities are provided by an I/O port 218, 
coupled to the local processor 40 (of FIG. 1); tiser I/O 
40 adapter 220, for communicating with user 80; and modem 
222, coupled to the central processing facility 60 (of FIG. 1); 
all also coupled to the system bus 216 in a known manner. 
Other adapters (not shown) may be coupled to system bus 
216 to provide other capabilities to the processing unit 224. 
45 As described above, auxiliary data extractor 204, I/O port 
218 and modem 222 are not required in a client computer 20 
according to the present invention. They are illustrated in 
FIG. 1 and FIG. 4 to show optional additional functionality. 
In operation, processor 210 of processing unit 224 
50 retrieves program instruaions permanently stored in ROM 
214, or temporarily stored in RAM 212, and executes the 
retrieved instructions to read data from ROM 212 and/or 
RAM 214, write data to RAM 212 and/or receive data from 
or supply data to outside sources via the I/O port 218, user 
55 I/O adapter 220 and/or modem 222, in a known manner. 
Under program control, processor 210 may also request a 
code and/or dau module &om the data stream supplied to the 
client computer 22 via the transport mechanism 30 (of FIG. 
1). To retrieve this dau, processor 210 first instructs stream 
60 I/O adapter 208 to send a selection control signal to the 
stream selector 202, possibly in response to user input from 
user I/O adapter 220. Then processor 210 issues a request for 
a specific code or data module to the stream I/O adapter 208. 
Stream I/O adapter 208 relays this request to the packet data 
65 extractor 204, 

Transport mechanism 30 (of FIG, 1) supplies all of the 
plurality of packet: streams (32-38 of ) it carries to the 



13 

slrcam selector 202, which passes only the selected packet 
stream. Auxiliary data extractor 204 monitors the selected 
packet stream, extracts the auxiliary data packets from it and 
supplies them directly to the auxiliary data processor 50 (of 
FIG. 1), Packet data extractor 206 similarly monitors the 5 
selected packet stream, extracts the directory, code and/or 
data module packets requested by the stream I/O adapter 208 
and supplies them to the stream I/O adapter 208. The data in 
the packets returned to the stream I/O adapter 208 is 
supplied to the RAM 212. When the entire module has been lO 
retrieved from the packet stream (which may require several 
packets, as described above), processor 210 is notified of its 
receipt by the stream I/O adapter 208, Processor 210 may 
then continue execution of its program. 

The data stream in a distributed computing system illus- is 
trated in FIG. 1 is similar to a mass storage system in prior 
art systems. An application program executing on the pro- 
cessor 210 makes a request for a module listed in the 
directory in the same maimer that such a program would 
make a request for a file containing a code or data module 20 
previously stored on a mass storage device in a prior art 
system. The data stream receiver 207 is similar to a mass 
storage device, and stream I/O 208 acts in a similar manner 
to a mass storage adapter on a prior an system by locating 
the desired data, tran^erring it to a predetenmDed location 25 
(I/O buffer) in the system memory and informing the pro- 
cessor of the completion of the retrieval. However, the 
stream I/O adapter 208 can only retrieve code and data from 
the data stream; data cannot be written to the data stream. 

As described above, the distributed computing applica- 30 
tion may be divided into more than one code module, each 
containing executable code for a different portion of the 
distributed computing application. When a particular code 
module is desired, processor 210 requests that code module 
from stream I/O adapter 208. When execution of that 3S 
module has completed, processor 210 requests the next 
module from stream I/O 208. Because code and data mod- 
ules are repetitively carried on the data stream, a module 
may be deleted from RAM 212 when it is not currently 
needed without the necessity of temporarily being stored, 4o 
because if it is required later, it may again be retrieved from 
the data sueam when needed. However, if RAM 212 has 
sufficient capacity, processor 210 may request stream I/O 
adapter to simultaneously load several code modules into 
RAM 212. If this car, be done, then processor 210 may 45 
switch between code modules without waitii^ for stream 
I/O adapter 20S to extract them from the data stream. 

As described above, other I/O adapters may be coupled 
to the system bus 216 in a known manner. For example, in 
an interactive TV system, a graphics adapter may be coupled so 
to system bus 216. The graphics adapter generates signals 
representing graphical images, in a known maimer, in 
response to instructions from the processor 210. Further, 
these signals may be combined with the standard video 
signal produced by the video decoder (described above) in 55 
the auxiliary data processor 50 of an interactive TV system. 
When the graphical image representative signal and the 
standard video signal are combined, the resulting signal 
represents an image in which the image generated by the 
graphics adapter is superimposed on the image represented 60 
by the broadcast video signal. It is also possible to selec- 
tively combine these two image representative signals under 
the control of the processor 210. 

An interactive TV system, may also include a sound 
adapter coupled to the system bus 216. The sound adapter 65 
generates a signal representing a computer generated sound 
(such as music, synthesized voice or other sound), in a 
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known manner, in response to instructions from the proces- 
sor 210. Further, these signals may be combined with the 
standard audio signal produced by the audio decoder 
(described above) in the auxiliary data processor 50 of an 

5 interactive TV system. When the sound representative signal 
and the standard audio signal are combined^ the resulting 
signal represents the combination of the sound generated by 
the sound adapter and the broadcast audio signal. It is also 
possible to selectively combine these two sound represen- 
tative signals under the control of the processor 210. 

The timing of the generation and display of the graphical 
image and sound representative signals, may be controlled 
by receipt of the time code data from the data stream. This 
enables an executable code module to synchronize the 
display of processor generated image and presentation of 

15 processor generated sound to the broadcast video and audio. 
It is further possible to synchronize the operation of the 
interactive TV application by the insertion of specialized 
packets into the data stream which cause an interrupt of the 
code currently executing in processor 210. Stream I/O 208 

20 monitors the data stream for such specialized packets, and 
generates an interrupt, in a known manner, for the processor 
210. Processor 210 responds to that interrupt, also in known 
manner, by executing an interrupt service routine (ISR). This 
ISR may be used for synchronization of the interactive TV 

25 application, or other purposes. 

A client computer 22 in a distributed computing system 
as illustrated in FIG. 1 docs not need a mass storage device, 
nor a large amount of RAM 212. Such a system decreases 
the cost of a client computer, and increases the functionality 

3Q of the lower cost client computers. In addition, such a clietit 
computer has the option of participating in a distributed 
computing function, may join in the distributed computing 
function at any time (or may drop out and return later), and 
may participate at its own pace. 

35 What is claimed is: 

1. A distributed computer system comprising: 

a source of a data stream providing a series of time 
division multiplexed packets, ones of which contain 
auxiliary data that represent a video program, and 

40 others of which represent a distributed computing 
application associated with said video program, and 
wherein said distributed computing application is 
repetitively transmitted independent of receiving client 
computer apparatus during times that said video pro- 

45 gram is transmitted; 

a client computer, which includes a packet selector con- 
nected to said source for selecting and directing packets 
conuining said auxiliary data representing said video 
program to a video signal processor and selecting and 

50 directing packets containing said associated distributed 
computing application to a further processor, and 
said further processor including means to assemble said 
distributed computing application and execute said 
distributed computing application to form an interac- 

55 tive video program in which execution of said distrib- 
uted computing application alters said video program. 

2. The distributed computer system of claim 1 wherein 
said further processor includes a graphics adapter for cre- 
ating graphical images and interactively combining said 

60 graphical images with said video program. 

3. The distributed computer system of claim 1 wherein 
said video program is a television program and said further 
processor includes a graphics adapter for creating graphical 
images and interactively combining said graphical images 

65 with said television program, 

4. The distributed computer system of claim 1 wherein 
said further processor includes a sound adapter for creating 
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synthesized sound and interactively combining said synthe- 
sized sound widi said video program. 

5. The distributed computer system of claim 1 wherein 
said further processor includes memory for storing program 
controls and responsive thereto requests of said packet 5 
selector a code and/or data module torn the data stream. 

6. A distributed computer system comprising: 

a source of a time division multiplexed packet signal 
including a plurality of distributed computing 
applications, each distributed computing application 1° 
being repetitively transmitted independent of receiving 
client computer apparatus, and each of said distributed 
computing applications being in a form of a series of 
packets; 

a first one of packets of a respective series containing data 
representing an executable code module atKi including 
identification information indicating that the first one of 
packets of said series contains data representing said 
executable code module; 

20 

a second one of packets of the series contains data 
representing a data module and includes identification 
information indicating that said second one of packets 
contains data representing the data module; and 

a third one of packets of the series contains auxiliary data 25 
and includes identification information indicating that 
the third one of packets contains auxiliary data; 

a client computer including a data receiver for selecting 
packets of one of the plurality of distributed computing 
applications, and extracting the corresponding distrib- 30 
uted computing application representative data 
included in the selected packets and applying it to 
computer program controlled apparatus for executing 
the extracted distributed computing application, said 
data receiver extracting auxiliary data horn auxiliary 35 
packets in the data stream and supplying it to an 
auxiliary data processor. 

7. A distr^uted computer system comprising: 

a data stream source producing a data stream including a 
series of packets representing a plurality of time divi- ^ 
sion multiplexed signals, one of said signals including 
data representing a distributed computing application, 
which distributed computing application is repetitively 
transmitted independent of receiving client computer 
apparatus, and at least one of the padcets of the signal 
representing the distributed computing application 
includes a directory module containing information 
inter-relating packets associated with said distributed 
computing application; 

a client computer, receiving Uie data stream, extracting the 
distributed computing application representative data 
from the data stream, and executing the extracted 
distributed computing application; and wherein 

the client computer extracts said directory module firom 
the data stream and using data contained in the direc- 
tory module extracts packets associated with said dis- 
tributed computing application and builds said distrib- 
uted computing application and executes said 
distributed computing application. ^ 

8. The computer system of claim 7, wherein: 

a first one of the series of packets contains data repre- 
senting an executable code module and includes iden- 
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tification informatioD indicating that the first one of the 
series of jackets contains data representing an execut- 
able code module; 

a second one of the series of packets contains data 
representing a data module and includes identification 
information indicating that the second one of the series 
of packets contains data representing a data module; 

a third one of the series of packets contains data repre- 
senting said directory module inter-relating respective 
transmitted modules associated with a single distrib- 
uted computing application, and includes identification 
information indicating that tiie third one of the series of 
packets contains data representing said directory mod- 
ule; and 

a fourth one of the series of packets contains auxiliary 
data and includes identification information indicating 
that the fourth one of the series of packets contains 
auxiliary data. 
9. In a distributed computer system, a client computer, 
comprising: 

an input terminal for receiving a packet data stream 
including packets of video signal time multiplexed with 
packets of data representing a distributed computing 
application which distributed computing application is 
repetidvely transmitted independently of said client 
computer and at least one of the packets representing 
the distributed computing application includes a direc- 
tory containing inforaiatioa inter-relating ones of the 
packets containing said distributed computing applica- 
tion; 

a data stream receiver, coupled to said input terminal, for 
receiving the data stream, providing separate data 
streams of said video signal and said distrft>uted com- 
puting application, extracting said directory padcet and 
responsive to the directory, extracting packets conuin- 
ing said distributed computing application representa- 
tive data; and 

a processing utiit, coupled to the data stream receiver, for 
assembling said distributed computing application and 
executing the distributed computing appUcation com- 
prising: 
a system bus; 

read/write memory, coupled to the system bus; 
a data stream input/output adapter, coupled between the 
dau stream receiver and the system bus, for receiv- 
ing the extracted distributed computing application 
representative data horn the data stream receiver, 
and storing it in the read/write memory, and having 
a control output terminal coupled to the selection 
control input terminal of the data stream selector, for 

55 producing the selection control signal; and 

a processor, coupled to the system bus, for controlling 
the data stream input/output device to generate a 
selection control signal selecting a specified one of 
the plurality of data streams, and for assembling and 

50 executing the distributed computing application 

stored in the read/write memory. 



10. A method of ordering an item using a distributed computing system 
including at least one client (20) and at least one server (10), the method 
comprising: 



showing and /or describing an item offered for sale to a user (80) via the 
client: 



enabling the user to order the item by a single interaction with the client: 
and 

in response to the single interaction with the client (20). placing an order 
for the offered item. 

11, The method of claim 10, wherein the single interaction is by one of the 
group including: 

a pressing of a single button: and 



a pressing of a single button on a TV remote control 



12. The method of claim 10, wherein placing the order is achieved by using: 



information related to the item being offered for sale: and 



user related personal information. 
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13. The method of claim 12, wherein the personal information includes at 
least one of the group including a user's name, address, method of payment and 
credit card number. 

14. The method of claim 12. wherein the personal information is stored in 
memory in the client. 

15. The method of claim 10. wherein the distributed computing system is an 
interactive television system and wherein the showing and /or describing of the 

i;i item is. at least in part, by television signal. 

16. The method of claim 10. wherein the client (20^ includes an auxiliary data 
J™ processor (50) and a client computer (22.24.26). 

I:'"; 17. The method of claim 12. wherein the client (20) is associated with at least a 
^ set top box, and wherein the personal information is stored at the set top box. 

18. The method of claim 17. wherein the set top box is in communication with 
a local computer (40) and associated storage (70) and wherein the method further 
comprises: 

the client (20) retrieving information from one or more of the local 
computer (40) and the mass storage (70). 

19. The method of claim 18. wherein the method further comprises: 
controlling the client (20) by means of the local computer (40). 
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20. The method of claim 18 > wherein the local computer (40) is part of a local 
area network. 

21. The method of claim 10, wherein the system further includes a central 
processing facility (60) in communication with the server (10) and wherein the 
method comprises: 

sending information used in processing the order from the client (20) to 
the central processing facility (60). 

22. The method of claim 10. further comprising: 

sending an order confirmation to the user (80) to confirm the order. 

23. The method of claim 21, further comprising: 

commimicating information between the client (20) and the server (10) via 
the central processing facility (60). 

24. The method of claim 23, wherein a telephone system acts as the central 
processing facility (60). 

25. The method of claim 10 including receiving at the client (20) a data stream 
including: 

(a) information to show and/ or describe the item offered for sale via 
the client: and 
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the item by the single interaction with the clieni-. 

26: The method of claim 2 5 wherein the data stream further includes an itpm 

identifier to identify the item offered for sale. 

2Z: The method of claim 26 wherein the item identifier includes any one a 

group of i dentifiers including a time code and a command. 

28. A method of ordering an item, the method comprising: 

providing a client with inf ormation to show and /or describe an item 
offered for sale to a user: and 

providing the client with an application to enable the user to order thp 
item by a single interaction with a client, responsive to which an order is 
placed for the offered item. 

22: The method of claim 28 . wherein the sing le int eraction comprises any nnp 

of the group including: 

a pressing of a single button: and 

a pressing of a single button on a TV remote control. 



24 




30. The method of claim 28, including receiving the order from the client, the 
order including: 

information related to the item being offered for sale: and 

user related personal information. 

31i The method of claim 30, wherein the personal information comprises any 

one of the group including a user's name, address, method of payment and 
credit card number. 

32;: The method of claim 30, wherein application is to retrieve the personal 

information from a memory associated with the client. 

33:^ The method of claim 28, includin g providing the information in the form 

of a television signal. 

Mi The method of claim 28 including communicating with a central 

processing facility (60) and wherein the client sends the order to the central 
processin g facility (60) for receipt via a transceiver (103). 

25: The method of claim 34 wherein a telephone system acts as the central 

processing facility (60). 

26: Th e method of claim 28 including providing an order confirmation to the 

client to confirm the order. 
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37. The method of claim 28 including multiplexing the provision of the 
information and the application to the client to thereby generate a data stream 
for transmission to the client. 

38. A computer system to order an item, the system comprising: 

a data processing system (50) to show and /or describe an item offered for 
sale to a user (80); and 

a client (22. 24. 26, 50) to enable the user to order the item by a single 
interaction with the client and, in response to the single interaction, to 
place an order for the offered item. 

39. The system of claim 38. wherein the single interaction comprises any one 
of the group including: 

a pressing of a single button: and 

a pressing of a single button on a TV remote control. 

40. The system of claim 38. wherein the client is to place the order using: 
information related to the item being offered for sale: and 

user related personal information^ 
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^ The system of claim 40. wherein the personal information comprises any 

one of the group including a user's na me, address, method of payment and 
credit card number. 

^ The system of claim 40. wherein the personal information is storpH in 

memory of the client. 

^ The system of claim 38. wherein the distributed computing system is an 

interactive television system and wherein the showing and /or describing of the 
item by the data processing system (5 0) is. at least in part, performed ntibVing a 
television signal. 

^ The system of claim 38. w herein the client (20^ inrlndes a client roTnp ntPr 

^ The system of claim 38. wherein the di ent computer (22) is assnrjated with 

at least a set top box, and wherein th e personal information is stored at the spt 
top box. 

^ The system of claim 45. wherein thp s et top box is in communication with 

a local computer (40^ an d associated storage ^7n^ and wherein thp rlipnf 
computer (22) is to retrieve informati on from one or more of the local compntpr 
(40) and the mass storage (70). 

^ The system of claim 46. wherein thP Inr al computer (40) controls thP rlipnt 

computer (22). 
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48: The syste m of claim 46, wherein the local computer (40^ is part of a loral 

area network, 

49: The syste m of claim 38, including a central processing facility (60)\r\ 

commimication with a server (10^ and wherein the client (20) sends information 
used in processing to the central processing facility (60). 

50, The system of claim 49 wherein the server (10) is to send an order 

confirmation to the user (80) to confirm the order. 

5L The syste m of claim 49. wherein the central processing facility (60) is to 

communi cate information between the client and the server (10). 

52: The syste m of claim 51 wherein a telephone system acts as the central 

processing facility (60). 

53:^ The system of claim 3 8 including a data stream receiver (207) to receive a 

data stream including: 

information t o show and /or describe the item offered for sale via the 
client: and 

an application, executable by the client, to enable the user to order thp 
item by a single interaction with the client. 
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54. The system of claim 53 wherein the data stream receiver (207) includes an 
auxiliary d ata extractor (204) to extract the information from the data stream and 
a packet da ta extractor (206) to extract the application from the data stream. 

55. The system of claim 54 wherein the auxiUary data extractor (204) provides 
the inform ation to the data processing system (50) and the packet data extractor 
(200) provides the application to the client (224). 

56. The system of claim 53 wherein the data stream further includes an item 

identifier to identify the item offered for sale. 

57. The system of claim 56 wherein the item identifier includes any one a 
group of identifiers including a time code and a command. 

5S. A computer system to facilitate ordering an item, the system comprising: 

a data source (107) to pr ovide a client with information to show and /nr 
describe an item offered for sale to a user: and 

an application source (101) to provide a client with an application to 
enable the use r to order the offered item by a single interaction with a 
client, responsi ve to which an order is placed for the offered item. 
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59. The system of claim 58, wherein the single interaction comprises any one 
of the group including: 

a pressing of a single button: and 

a pressing of a single button on a TV remote control. 

60. The system of claim 58, including a data receiver (103) to receive the order 
from the client, the order including: 

]g information related to the offered item: and 

user related personal information. 

M 61. The system of claim 60. wherein the personal information comprises any 

Q one of the group including a user's name, address, method of payment and 

.-i credit card number. 

62: The system of claim 60, wherein application is to retrieve the personal 

information from a memory associated with the client. 

61 The system of claim 58. wherein the data source (107) is to provide the 

information in the form of a television signal. 

64 The system of claim 5 8 including a data transceiver (103) to communicate 

with a central processi ng facility (60) and wherein the client sends the order to 
the central processing facili tv (60) for receipt via the data transceiver (103). 



30 



65. The system of claim 64 wherein a telephone system acts as the central 
processing facility (60V 

66. The system of claim 58 wherein the data source (107) is to provide an 
order confirmation to the client to confirm the order. 

6Z: The system of claim 58 including a multiplexer to multiplex the provisinn 

of the information and the application to the client to thereby generate a data 
stream for transmission to the client. 
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68. A method of ordering an item using an interactive television system 
including at least one client ill. 50) and at least one server (10), the method 
comprising: 

using the server (10) to provide data, some of which represents video and 
some of which represents a computing apphcation, to the client: 

at the client, causing the video to be displayed, and executing the 
computing application to cause display of interactive information: 

using one or more of the displayed video and the interactive information 
to show and/ or describe an item offered for sale to a television viewer 

mi 

enabling the viewer (80) to select the item by interacting with the client 
(22,50): and 

in response to the viewer interaction, placing an order for the displayed 
item. 



69. The method of claim 68, wherein the user interaction causes display of 
instructions to solicit information necessary to place the order. 

ZQ^ The meth od of claim 69, wherein the information is solicited using one or 

more of an on-screen display and voice instructions. 
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71. The method of claim 68> wherein the viewer interaction is by way of a 
single command. 

72. The method of claim 71. wherein the single command is by one of the 
group of: 

the pressing of a single button: and 

the pressing of a single button on a TV remote control. 

';z 73. The method of claim 68. wherein placing the order is achieved by using: 

information related to the item being offered for sale and viewer related personal 
information. 

i.o 

74. The method of claim 73, wherein the personal information includes at 

UJ 

H least one of the group consisting of the viewer's name, address, method of 
Q payment and credit card number. 

75. The method of claim 74. wherein the personal information is stored in 
memory at the client (22. 50V 

76. The method of claim 74. wherein the system further includes a local 
computer (40) and associated storage (70) and wherein the method further 
comprises: 

using the client (22. 50) to retrieve information from one or more of the 
local computer (40) and the mass storage (70). 
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77. The method of claim 76. wherein the method further comprises: 
controlling the client (20, 50) by means of the local computer (40V 

78. The method of claim 76 > wherein the local computer (40) is part of a local 
area network. 



79. The method of claim 68, wherein the system further includes a central 
processing facility (60) in commtmication with the server (10) and wherein the 
method comprises: 



communicating information between the client (22, 50) and the server (10) 
via the central processing facility (60). 

81. The method of claim 79, wherein a telephone system acts as the central 
processing facility (60V 

82. The method of claim 68, further comprising: 



sending information used in processing the order from the client 
computer (22) to the central processing facility (60). 




Q 



80. The method of claim 79, further comprising: 
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sending an order confirmation to the user (80) to confirm the order. 

83. The method of claim 68. wherein the server (10) provides data in a series 
of multiplexed packets, ones of which contain data representing the video, and 
others of which represent the computing application. 

84. The method of claim 83, wherein the computing application is repetitively 
transmitted during times that the video is transmitted. 

r;3 85. The method of claim 83, wherein the client (22,50) includes a client 
;3 computer (22) and an auxiliary processor (50), the method comprising: 

] V I 

3 using the auxiliary data processor (50) to process data representing the 

II video, and 

! using the client computer (22) to execute the computing application. 

Q 86. The method of claim 85, wherein the client computer and the auxiliary 

I -KM! 

data processor are contained in a set top box. 

87. A method of ordering an item using an interactive television system, the 
method comprising: 

receiving data, some of which represents video and some of which 
represents a computing application: 

causing the video to be displayed: 
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executing the computing application to cause display of interactive 
information; 

using one or more of the displayed video and the interactive information 
to shov^ and /or describe an item offered for sale to a television user (SO): 

enabling the user (80) to select the item by way of an interaction: and 

in response to the interaction, placing an order for the displayed item. 

Hp 88. The method of claim 87. wherein the viewer interaction causes display of 
m instructions to solicit information necessary to place the order. 

89. The method of claim 88. wherein the information is solicited using one or 
^ more of an on-screen display and voice instructions. 

'H 90. The method of claim 87, wherein the viewer interaction is by way of a 

sin gle command. 

91. The method of claim 90. wherein the single command is by one of the 
group of: 

the pressing of a single button; and 

the pressing of a single button on a TV remote control. 
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92. The method of claim 87, wherein placing the order is achieved by using: 
information related to the item being offered for sale and user related personal 
information. 

93. The method of claim 92. wherein the personal information includes at 
least one of the group consisting of the user's name, address, method of payment 
and credit card number. 

94. The method of claim 93, wherein the personal information is stored in 
local memory. 

95. The method of claim 87, further comprising: 
commimicating information via a central processing facility (60). 

96. The method of claim 95, wherein a telephone system acts as the central 
processing facility (60V 

97. The method of claim 87, further comprising receiving an order 
confirmation to the user (80) to confirm the order. 

98. The method of claim 87, wherein the data comprises a series of 
multiplexed packets, ones of which contain data representing the video, and 
others of which represent the computing application. 

99. The method of claim 87, wherein a client (22,50) includes a client 
computer (22) and an auxiliary processor (50), the method comprising: 
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using the auxiliary data processor (50) to process data representing the 
video, and 

using the client computer (22) to execute the computing application. 

100. The method of claim 99. wherein the client computer and the auxiliary 
data processor are contained in a set top box. 



101. A method of ordering an item using an interactive television system^ the 
method comprising: 

^ providing data, some of which represents video to be displayed and some 

of which represents a computing application to be executed to display 

^ interactive information, to the client, the client to use one or more of the 

Q displayed video and the interactive information to show and /or describe 

an item offered for sale to a television user (80) and to enable the user (80) 

Q to select the item by interacting with the client (22. 50): and 

in response to the interaction, receiving an order for the displayed item. 

102. The method of claim 101, wherein the received order includes: 
information related to the item being offered for sale and user related personal 
information. 
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103. The method of claim 102. wherein the personal information includes at 
least one of the group consisting of the user's name, address, method of payment 
and credit card number. 

104. The method of claim 101. including providing the data in a series of 
multiplexed packets, ones of which contain data representing the video, and 
others of which represent the computing application. 

105. The method of claim 101, wherein the computing application is 
repetitively transmitted during times that the video is transmitted. 
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1 06. An interactive television system comprising: 



a server (10) to provide data, some of which represents video and some of 
which represents a computing application, to the cUent: 

a client to: 

cause the video to be displayed; 

execute the computing application to cause display of interactive 
information: 

use one or more of the displayed video and the interactive 
information to show and /or describe an item offered for sale to a 
television user (80): 

enable the user (80) to select the item by interacting with the client 
(2250): and 

in response to the interaction, place an order for the displayed item. 

107. The system of claim 106, wherein the user interaction causes display of 
instructions to solicit information necessary to place the order. 

108. The system of claim 107, wherein the information is solicited using one or 
more of an on-screen display and voice instructions. 
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109. The system of claim 106, wherein the interaction is by way of a single 
command. 



110. The system of claim 109, wherein the single command is by one of the 
group of: 

the pressing of a single button: and 

the pressing of a single button on a TV remote control. 

Q 111. The system of claim 106, wherein placing the order is achieved by using: 
information related to the item being offered for sale and user related personal 
y information. 

i/ 112, The system of claim 111, wherein the personal information includes at 

^ least one of the group consisting of the user's name, address, method of payment 

; and credit card number. 

113, The system of claim 111, wherein the personal information is stored in 
memory at the client (22, 50). 

114. The system of claim 111 , wherein the system further includes a local 
computer (40) and associated storage (70) and wherein the method further 
comprises: 

using the client (22, 50) to retrieve information from one or more of the 
local computer (40) and the mass storage (70). 
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115. The system of claim 106. wherein the client (20. 50) is to be controlled by 
means of the local computer (40V 



116. The system of claim 115. wherein the local computer (40) is part of a local 
area network. 

117. The system of claim 106, wherein the system further includes a central 
processing facility (60) in communication with the server (10) and wherein the 
client is to send information used in processing the order to the central 
processing facility (60). 

118. The system of claim 117, wherein the client (22, 50) is to commimicate 
with the server (10) via the central processing facility (60). 

119. The system of claim 118. wherein a telephone system acts as the central 
processing facility (60). 

120. The system of claim 106, wherein the server is to send an order 
confirmation to the user (80) to confirm the order. 

121. The system of claim 106. wherein the server provides data in a series of 
multiplexed packets, ones of which contain data representing the video, and 
others of which represent the computing application. 

122. The system of claim 106. wherein the computing application is repetitively 
transmitted during times that the video is transnutted. 
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123. The system of claim 106, wherein the client (22,50) includes a client 
computer f22) and an auxiliary processor (50). and: 

the auxiliary data processor (50) is to process data representing the video, 
and 

the client computer (22) is to execute the computing application. 

124. The system of claim 123, wherein the client computer and the auxiliary 
data processor are contained in a set top box. 

'IJ 125. An interactive television system to order an item, the system comprising : 

\M a receiver (207) to receive data, some of which represents video and some 

of which represents a computing application: and 

I! 

□ a processing imit (224) to: 

□ 

execute the computing application to cause display of interactive 
information: 

using the interactive information, show and /or describe an item 
offered for sale to a television user (80): 

enable the user (80) to select the item by way of an interaction: and 
in response to the interaction, place an order for the displayed item. 
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126. The system of claim 125. wherein the interaction causes the processing 
unit to display instructions to solicit information necessary to place the order. 

127. The system of claim 126. wherein the information is solicited using one or 
more of an on-screen display and voice instructions. 

128. The system of claim 125. wherein the interaction is by way of a single 
command. 

129. The system of claim 128. wherein the single command is by one of the 
group of: 

the pressing of a single button: and 

the pressing of a single button on a TV remote control. 

130. The system of claim 125. wherein the processing unit places the order 
using: 

information related to the item being offered for sale and user related 
personal information. 

131. The system of claim 130. wherein the personal information includes at 
least one of the grou p consisting of the user's name, address, method of payment 
and credit card number. 
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132. The system of claim 130. including a local memory to store the personal 
information memory. 

133. The system of claim 125, further comprising a central processing facility 
(60^ to communicate information. 

134. The system of claim 133. wherein a telephone system acts as the central 
processing facility (60). 

135. The system of claim 125. further comprising a receiver to receive an order 
confirmation to confirm the order. 



136. The system of claim 125. wherein the data comprises a series of 
multiplexed packets, ones of which contain data representing the video, and 
others of which represent the computing application, the system including a first 
extractor to extract the video and a second extractor to extract the computing 
application from the data. 

137. The system of claim 125, including : 

an auxiliary data processor (50) to process the video, and 
a client computer (22) to execute the computing application. 



138. The system of claim 137. wherein the client computer and the auxiliary 
data processor are contained in a set top box. 
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139. An interactive television system to order an item, the system comprising: 

a server (10) to provide data, some of which represents video to be 
displayed and some of which represents a computing application to be 
executed to display interactive information^ to a client, the client to use 
one or more of the displayed video and the interactive information to 
show and /or describe an item offered for sale to a television user (80) and 
to enable the user (80) to select the item by interacting with the client 
(22,50): and 

a receiver, in response to the interaction, to receive an order for the 
displayed item. 

140. The system of claim 139, wherein the received order includes: 

information related to the item being offered for sale and user related 
personal information. 

141. The system of claim 140, wherein the personal information includes at 
least one of the group consisting of the user's name, address, method of payment 
and credit card number. 

142. The system of claim 139, wherein the server is to provide the data in a 
series of multiplexed packets, ones of which contain data representing the video, 
and others of which represent the computing application. 
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143. The system of claim 16. wherein the server is to repetitively transmit the 
computing application during times that the video is transmitted. 

144. A method of placing an order for an item, the method comprising: 

using a server system: 

communicating a data stream to a client system, the data stream 
including information related to an item offered for sale; and 

using a client system: 

receiving an order request from a user: 

automatically determining an item identity for an item to which the 
order request pertains utilizing the information related to the item 
offered for sale; 

automatically retrieving personal information of the user 
previously stored in a storage device: and 

placing an order, including the item identity and the retrieved 
personal information^ 

145. The method of claim 144 wherein the order request is received at the client 
system through detection of a purchase action by the user utilizing the client 
system. 
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1 46. The method of claim 145 wherein the purchase acti on is performed during 
the showing and /or describing of the item via the cl ient system utilizing the 
information related to the item offered for sale. 

1 47. The method of 145 wherein the purchase action inc ludes input of the item 
identity into the client system. 

1 48. The method of claim 145 wherein the automatic determination o f the item 
i;3 identity includes relating the purchase action to the in formation related to the 

"zhsr 

item. 

□ 

i = II 

rC 149. The method of claim 148 wherein the relating includes the detecti ng of the 

purchase action during an offer of the item as specifie d any one of a group 

;;i including by a time code and a command included within the in formation relate 

to the item. 

150. The method of claim 144 wherein the item identity is received within the 
data stream trai\smitted from the server system to the cl ient system. 

1 51 . The method of claim 144 wherein the data stream includes m ultiplexed 
first and second streams of packets, the first stream of packets including display 
information to generate an image on a display of the cHent sys tem, and the 
second stream of packets including a computing application. 

152. The method of claim 149 wherein the time code is received w ithin the data 
stream transmitted from the server system to the client system. 
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153. The method of claim 145 including prompting the user to perform the 
purchase action utilizing the client system> 

154. The method of claim 153 wherein the prompting includes displaying a 
visual prompt on a display of the client system. 

155. The method of claim 154 wherein the visual prompt includes any of a 
group including an indicia, instructions and a menu. 

156. The method of claim 153 wherein the prompting includes generating an 
i.y audio prompt via an audio reproduction unit of the client system 

y, 

i>1 

n 157. The method of claim 156 wherein the audio prompt comprises any one of 

Q 

\} a group including instructions, options and a menu. 

Cl 158. The method of claim 145 wherein the detection of the purchase action 

includes detecting an interaction by the user with a control device of the client 
system. 

159. The method of claim 158 wherein the interaction comprises a single action 
operation performed by the user. 

160. The method of claim 159 wherein the single action operation comprises a 
sin gle selection of a button of a remote control device. 
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16L The method of claim 144 wherein the storage device is associated with the 
client system and wherein the order is placed by the client system and 
communicated to the server system. 

162. The method of claim 144 including receiving a client application program 
at the client system from the server system, the client application program to 
place the order. 

163. The method of claim 162 wherein the client application program is 
□ received as part of the data stream. 

■5 

LJ 164. The method of claim 144 including receiving, at the client system from the 

iJl server system, an order confirmation responsive to a processing of the order by 

Co 

the server system. 

165. A method of placing an order for an item, the method comprising: 

0 

receiving an order request from a user at a client system: 

automatically deternnining an item identity for an item to which the order 
request pertains: 

automatically retrieving personal information of the user previously 
stored in a storage device; and 
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placing an order, includ in g the item identity and the retrieved personal 
information, for processing by a server system in co mmimication with the 
client system. 

1 66. The method of claim 165 wherein the order request is received at the client 
system through detection of a purchase action bv the user utilizing the client 
system. 

1 The method of daim 166 wherein the purchase action is perfor med during 
p the showing and /or describing of th e item via the client system. 

17! 1 68. The method of 1 66 wherein the purchase action includes inpu t of the item 
m identity into the client system. 

iii 

!:i 169. The method of daim 166 including receiving inform ation, at the client 

— 

system from the server system, related to the item and wherein the automatic 
determination of the item identity includes relating th e purchase action to the 
received information related to the item. 

170. The method of claim 169 wherein the relating includes the detecting of the 
purchase action during an offer of the item as sp ecified any one of a group 
including by a time code and a command included wi thin the received 
information relate to the item. 

171. The method of claim 165 wherein the item identity is rece ived within a 
data stream transmitted from the server system to the cl ient system. 
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172. The method of claim 171 wherein the data stream includes multiplexed 
first and second streams of packets, the first stream of packets including display 
information to generate an image on a display of the client system, and the 
second stream of packets including an computing application. 

173. The method of claim 170 wherein the time code is received within a data 
stream transmitted from the server system to the client system. 

174. The method of claim 166 including prompting the user to perform the 
purchase action utilizing the client system. 

175. The method of claim 175 wherein the prompting includes displaying a 
visual prompt on a display of the client system. 

176. The method of claim 175 wherein the visual prompt includes any of a 
group including an indicia, instructions and a menu. 

177. The method of claim 174 wherein the prompting includes generating an 
audio prompt via an audio reproduction unit of the client system 

178. The method of claim 177 wherein the audio prompt comprises any one of 
a group including instructions, options and a menu. 

179. The method of claim 166 wherein the detection of the purchase action 
includes detecting an interaction by the user with a control device of the client 
system. 
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180> The method of claim 179 wherein the interaction comprises a single action 
operation performed by the user. 

181. The method of claim 180 wherein the single action operation comprises a 
sin gle selection of a button of a remote control device. 

182. The method of claim 165 wherein the storage device is associated with the 
client system and wherein the order is placed by the client system and 
communicated to the server system. 

183. The method of claim 165 including receiving a client application program 
at the client system from the server system, the client application program to 
receive the order request and to place the order. 

184. The method of claim 183 wherein the client application program is 
received as part of a data stream including content for display by the client 
system. 

185. The method of claim 165 including receiving, at the client system from the 
server system, an order confirmation responsive to the processing of the order by 
the server system. 

186. A method of facilitating placing of an order for an item, the method 
comprising communicating a data stream to a client system, the data stream 
including: 

information related to an item offered for sale; and 
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an application program for execution by the client system to receive an 
order request from a user, automatically to determine an item identity for 
an item to which the order request pertains utilizing the information 
related to the item offered for sale, automatically to retrieve personal 
information of the user previously stored in a storage device, and to place 
an order, including the item identity and the retrieved personal 
information. 

187. The method of claim 186 including inserting a time code and /or a 
command into the information related to the item. 

188. The method of claim 186 including inserting the item identity into the 
information related to the item. 

189. The method of claim 186 including generating the data stream to include 
multiplexed first and second streams of packets, the first stream of packets 
including display information to generate an image on a display of the client 
system, and the second stream of packets including the computing application. 

190. The method of claim 186 comprising including a visual prompt within the 
information related to the item offered for sale. 

191. The method of claim 190 wherein the visual prompt includes any of a 
group including an indicia, instructions and a menu. 
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192. The method of claim 186 comprising including an audio prompt within 
the information related to the item offered for sale. 

193. The method of claim 190 wherein the audio prompt comprises any one of 
a group including instructions, options and a menu. 

194. The method of claim 186 wherein the application program is for execution 
by the client system to detect an interaction by the user with a control device of 
the client system as a purchase action. 

195. The method of claim 194 wherein the interaction comprises a single action 
operation performed by the user. 

196. The method of claim 195 wherein the single action operation comprises a 
sin gle selection of a button of a remote control device. 

197. The method of claim 186 wherein a storage device is associated with the 
client system and wherein the order is placed by the client system and 
communicated to the server system. 

198. The method of claim 186 generating an order confirmation responsive to 
the processing of the order. 

199. A system to place an order for an item, the system comprising : 

a server system to transmit a data stream, the data stream including 
information related to an item offered for sale: and 
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receive the data stream: 



receive an order request from a user: 

automatically determine an item identity for an item to which the 
order request pertains utilizing the information related to the item 
offered for sale; 

automatically retrieve personal information of the user previously 
stored in a storage device: and 

place an order, including the item identity and the retrieved 
personal information. 

200. The system of claim 199 wherein the client system is to receive the order 
request through detection of a purchase action by the user. 

201. The system of claim 200 wherein client system is to detect the purchase 
action during the showing and /or describing of the item by the client system 
utilizing the information related to the item offered for sale. 

202. The system of claim 200 wherein the client system is to receive input of the 
item identity into the client system as part of the purchase action. 
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203. The system of claim 200 wherein the client system is to relate the purchase 
action to the information related to the item. 

204. The system of claim 203 wherein the clients system is to detect the 
purchase action during an offer of the item as sp ecified any one of a group 
including by a time code and a command included within the information relate 
to the item. 

205. The system of claim 199 wherein the data stream incl udes multiplexed 
first and second streams of packets, the first strea m of packets including display 
information to generate an image on a display of the dient sys tem, and the 
second stream of packets including an computing ap plication. 

^ 206. The system of claim 200 wherein the client system is to pr ompt the user to 

Q perform the purchase action utilizing the client system, 

%J 

i 

207. The system of claim 206 wherein the client system is to disp lay a visual 
prompt on a display of the client system. 

208. The system of claim 207 wherein the visual prompt includ es any of a 
group including an indicia, instructions and a menu. 

209. The system of claim 206 wherein the clients system is to genera te an audio 
prompt via an audio reproduction unit of the client system 

210. The system of claim 209 wherein the audio prompt comp rises any one of a 
group including instructions, options and a menu. 
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21 1 . The system of claim 200 wherein the clients system is to detect the 
purrhase action by detecting an interaction by the us er with a control device of 
the rlient s ystem. 

21 2. The system of claim 211 wherein the interaction co mprises a sinele action 
operation performed by the user. 

21 ?i. The system of claim 212 wherein the single action op eration comprises a 
□ sin gle selection of a button of a remote cont rol device. 

"xhS 
. Ft; 

y 21 4. The system of claim 1 99 wherein the storage device i s associated with the 

ij client system and wherein the order is placed bv the client system and 

'"^ rommunicated to the server system. 

ib 

21 S. The system of claim 199 wherein the client system is to receive a client 
Q appliration program from the server system, th e client application program 

bein g executable bv the client system to place the order. 

21 <S. The system of claim 215 wherein the client applica tion program is 
received as part of the data stream. 

21 7. The system of claim 199 wherein the client system i s to receive an order 
confirmation responsive to the processing of the order by the server system. 

21 8. A client system including: 
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an item offered for sale: and 



a processing unit (224) to: 

rpreive an order request from a user: 

automatically determine an item identity fo r an item to which the 
order request pertains utilizing the information relate d to the item 
offered for sale: 

automatically retrieve personal information of the user previously 
stored in a storage device: and 

place an order, including the item identity and the retrieved 
personal information. 

219. The system of claim 218 wherein the processing unit (224) is to receive the 
order request through detection of a purchase action b y the user, 

220. The system of claim 219 wherein proce ssing imit (224) is to detect the 
purchase action during the showing and/or describing of the item by the client 
system utilizing the information related to the item offered for sale. 

221. The system of claim 219 wherein the processing unit (224 ) is to receive 
input of the item identity as part of the purc hase action. 
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222> The system of claim 219 wherein the processing unit (224) is to relate the 
purchase action to the information related to the item. 

223. The system of claim 219 wherein the processing unit (224) to detect the 
purchase action during an offer of the item as specified any one of a group 
including by a time code and a command included within the information relate 
to the item. 

224. The system of claim 218 wherein the receiver (207) is to receive the data 

Q stream as multiplexed first and second streams of packets, the first stream of 

'■0 

in packets including display information to generate an image on a display of the 

client system, and the second stream of packets including an computing 
; ;| application, the receiver further including a first extractor (204) to extract the first 

'T' stream of packets from the data stream and a second extractor (206) to extract the 

second stream of packets from the data stream. 

225. The system of claim 219 wherein the processing unit (224) and / or the 
receiver (207) is to prompt the user to perform the purchase action utilizing the 
client system. 

226. The system of claim 225 wherein the processing imit (224) and /or the 
receiver (207) is to display a visual prompt on a display of the client system. 

227. The system of claim 226 wherein the visual prompt includes any of a 
group including an indicia, instructions and a menu. 
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228. The system of claim 228 wherein the processing unit (224^ and /or the 
receiver (207) is to generate an audio prompt via an audio reproduction unit of 
the client system 

229. The system of claim 228 wherein the audio prompt comprises any one of a 
group including instructions, options and a menu, 

230. The system of claim 219 wherein the processing tmit (224) is to detect the 
purchase action by detecting an interaction by the user with a control device of 

Q the client system. 

'lib? 

[3 231. The system of claim 230 wherein the interaction comprises a single action 

\fl operation performed by the user. 

•'i 232. The system of claim 231 wherein the single action operation comprises a 

single selection of a button of a remote control device. 

Q 

233. The system of claim 218 including storage device is associated with the 
client system and wherein the order is placed by the client system and 
commurucated to a server system. 

234. The system of claim 218 wherein the receiver (207) to receive a client 
application program from a server system, the client application program being 
executable by the processing unit (224) to receive the order request and to place 
the order. 
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235. The system of claim 234 wherein the receiver is to rec eive the client 
application program as part of the data stream. 

236. The svstem of claim 218 wherein the receiver ilQT) is to re ceive an order 
rnnfirmation responsive to the processing of the order by the server system. 

237. A server system to facilitate placing of an order f or an item, the system 
comprising: 

i:3 a data source to provide information related to a n item offered for 

up sale: and 

□ 

an a pplication source (101) to provide an application program for 
execution by the client system to receive an order request from a user, 
automatically to determine an item identity for an item to which the order 
request pertains, automatically to retrieve personal information of the user 
previously stored in a storage device, and to place an order, including the 
item identity and the retrieved personal information: and 

a multiplexer (106) to conununicate the information and t he application 
program to a client system. 

238. The system of claim 237 wherein the multiplexer is to generate the data 
stream to include multiplexed first and second streams of pac kets, the first 
stream of packets including display information to gene rate an image on a 
display of the client system, and the second stream of packets inclu ding the 
computing application. 
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239. The system of claim 237 wherein the application source and / or data 
source is to include a visual prompt within the information related to the item 
offered for sale. 



240. The system of claim 239 wherein the visual prompt includes any of a 
group including an indicia, instructions and a menu. 

241. The method of claim 237 wherein the application source and /or data 
source is to include an audio prompt within the information related to the item 
offered for sale. 

242. The method of claim 241 wherein the audio prompt comprises any one of 
a group including instructions, options and a menu. 



1'^ 243. The method of claim 237 wherein a detection of a purchase action by the 

C3 applicatio n program includes detecting an interaction by the user with a control 

device of the client system. 

244. The method of claim 243 wherein the interaction comprises a single action 
operation performed by the user. 

245. T he method of claim 244 wherein the single action operation comprises a 
single selection of a button of a remote control device. 
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